<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #box1{
            width: 300px;
            height: 300px;
            background-color: yellowgreen;
        }
        #box2{
            width: 200px;
            height: 200px;
            background-color: yellow;
        }
        #box3{
            width: 150px;
            height: 150px;
            background-color: skyblue;
        }
    </style>
    <script>
        window.onload=function(){
            /* 
            分别为三个div绑定单击响应函数
            */
           var box1=document.getElementById("box1");
           var box2=document.getElementById("box2");
           var box3=document.getElementById("box3");
           
           /* 
             事件的传播
             -古纳于时间的传播网景公司和微软公司由不同的理解
             -微软公司认为事件应该是自内向外传播，也就是当事件触发时，应该先触发当前元素上的事件
             谭厚在向当前元素的祖先元素上传播，也就是说事件应该在冒泡阶段执行
             -网景公司认为时间的应该是由外向内传播的，也就是当前事件触发时，应该先触发当前元素的最外层的祖先元素的事件
             然后再向内传播给后代元素
             -W3C综合了两个公司的方案，将事件传播分成了3个阶段
             1.捕获阶段
             -在捕获阶段时从最外层的祖先元素，向目标元素进行事件的捕获，但是默认此时不会触发事件
             12目标阶段
             -事件捕获到目标元素，捕获结束开始在目标元素上触发事件
             3.冒泡阶段
             -事件从目标元素向它的祖先元素传递，一次出发点祖先元素上的事件


             -如果希望子啊捕获阶段就触发时事件，可以将addEventListener()的第二个参数设置为true
             一般情况下我们不会希望在捕获阶段触发事件，所以这个参数一般都是false

             IE8及以下的浏览器中没有捕获阶段
           */

        bind(box1,"click",function(){
            alert("我是box1的响应函数")
        });
        bind(box2,"click",function(){
            alert("我是box2的响应函数")
        });
        bind(box3,"click",function(){
            alert("我是box3的响应函数")
        });
        };

        function bind(obj,evenStr,callback){
            if(obj.addEventListener){
                //大部分浏览器兼容的方式
                obj.addEventListener(evenStr,callback,false);   
            }
            else{
                /* 
                this 是谁由调用方式决定
                callback.call(obj)

                */
            }
        }
    </script>
</head>
<body>
   <div id="box1">
    <div id="box2">
        <div id="box3"></div>
    </div>
   </div> 
</body>
</html>